博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
正则表达式—贪婪与非贪婪模式
阅读量:7069 次
发布时间:2019-06-28

本文共 930 字,大约阅读时间需要 3 分钟。

hot3.png

今天在进行一个网页数据的抓取过程中遇到了一点点的问题,要进行网页中图片的抓取,翻来覆去只能取到最后一张图片的地址,不能进行全部的匹配,后查资料得知正则中的表达式默认情况下是贪婪模式的,所以匹配到了最后一个符合条件的表达式,下面贴出小例子,只是便于大家理解

51 $str = ''; 52 preg_match_all("//is", $str, $outstr); 53 print_r($outstr[1]);

这种情况匹配结果为:
Array(    [0] => a.jpg">

也就是匹配到了最后的一个图片地址,因为正则表达式在默认情况下是贪婪的,所以匹配到了最后一个图片地址。
preg_match_all("//is", $str, $outstr);

将代码改为上面的形式,则可以匹配出想要的结果,

Array ( [0] => a.jpg [1] => b.jpg [2] => v.jpg )

? 当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。例如,对于字符串 "oooo",'o+?' 将匹配单个 "o",而 'o+' 将匹配所有 'o'。

当正则表达式中包含能接受重复的限定符时,通常的行为是(在使整个表达式能得到匹配的前提下)匹配尽可能多的字符。考虑这个表达式:a.*b,它将会匹配最长的以 a开始,以b结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称为贪婪匹配。

有时,我们更需要懒惰匹配,也就是匹配尽可能少的字符。前面给出的限定符都可以被转化为懒惰匹配模式,只要在它后面加上一个问号?。这样.*?就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。现在看看懒惰版的例子吧:

a.*?b匹配最短的,以a开始,以b 结束的字符串。如果把它应用于aabab的话,它会匹配aab(第一到第三个字符)ab(第四到第五个字符)

转载于:https://my.oschina.net/yueguanqun/blog/66247

你可能感兴趣的文章
SQL Server中sp_spaceused统计数据使用的空间总量不正确的原因
查看>>
不一样的Java Enum
查看>>
Visual Studio 2015 和 Apache Cordova 跨平台开发入门
查看>>
Java Web之Cookie和Session的理解
查看>>
C#使用Xamarin开发可移植移动应用(4.进阶篇MVVM双向绑定和命令绑定)附源码
查看>>
spark 统计每天新增用户数
查看>>
使用.NET Core搭建分布式音频效果处理服务(二)创建基于FFMpeg的Web程序
查看>>
Python 面向对象程序设计
查看>>
LOWER
查看>>
Rust 全新官网已上线测试,这样的风格你喜欢吗?
查看>>
Git 使用总结
查看>>
OSS 监控
查看>>
Python爬虫之小猪短租房
查看>>
时隔 3 年,音频播放器 DeaDBeeF 发布 1.8.0 版本
查看>>
阿里云服务器架设javaweb网站全攻略
查看>>
py django web quickstart
查看>>
CCleaner v5.55.7108 发布,新增软件升级功能
查看>>
简书文章被锁定
查看>>
产品经理第三章:为什么我们的产品总是失败
查看>>
Centos7-tomcat已启动并且配置变量环境,依然无法进入
查看>>